package com.hxzy.service;

import com.hxzy.controller.admin.product.req.*;
import com.hxzy.controller.admin.product.resp.ProductResp;
import com.hxzy.controller.mobile.product.req.MobileProductReq;
import com.hxzy.controller.mobile.product.resp.MobileProductResp;
import com.hxzy.entity.Product;
import com.baomidou.mybatisplus.extension.service.IService;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
* @author admin
* @description 针对表【product(商品信息)】的数据库操作Service
* @createDate 2024-02-21 11:30:41
*/
public interface ProductService extends IService<Product> {

    /**
     * 分页查询
     * @param req
     * @return
     */
    List<ProductResp> search(ProductSearchReq req);

    /**
     * 新增商品
     * @param req
     * @return
     */
    boolean addData(ProductAddReq req);

    /**
     * 根据主键查询
     * @param id
     * @return
     */
    ProductResp findById(Long id);

    /**
     * 修改商品信息
     * @param req
     * @return
     */
    boolean updateData(ProductEditReq req);

    /**
     * 单个商品上下架
     * @param req
     * @return
     */
    boolean upOrDown(ProductUpOrDownReq req);

    /**
     * 修改库存
     * @param req
     * @return
     */
    boolean changeStock(ProductStockChangeReq req);


    /**
     * 批量下架
     * @param ids
     * @return
     */
    boolean batchDown(Long[] ids);

    /**
     * 商品信息
     * @param req
     * @return
     */
    List<MobileProductResp> mobileSearch(MobileProductReq req);

    /**
     *  扣库存
     * @param buyNumber
     * @param productDb
     * @return
     */
    long deduceNum(Integer buyNumber,Product productDb);
}
